home *** CD-ROM | disk | FTP | other *** search
/ Developer CD Series 1996 February: Tool Chest / Apple Developer CD Series Tool Chest February 1996 (Apple Computer)(1996).iso / Tool Chest / Development Tools & Languages / Macintosh Common Lisp Related / PowerLisp / PowerLisp 1.1.sea / PowerLisp 1.1 / Library / structures.lisp < prev   
MacBinary  |  1994-03-25  |  5.3 KB  |  [TEXT/ROSA]

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: MacBinary (archive/macBinary).

ConfidenceProgramDetectionMatch TypeSupport
10% dexvert MacBinary (archive/macBinary) fallback Supported
1% dexvert Text File (text/txt) fallback Supported
100% file MacBinary II, inited, Fri Mar 25 00:52:39 1994, modified Fri Mar 25 00:52:39 1994, creator 'ROSA', type ASCII, 4618 bytes "structures.lisp" , at 0x128a 428 bytes resource default (weak)
99% file data default
74% TrID Macintosh plain text (MacBinary) default
25% TrID MacBinary 2 default (weak)
100% siegfried fmt/1762 MacBinary (II) default
100% lsar MacBinary default


id metadata
keyvalue
macFileType[TEXT]
macFileCreator[ROSA]



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 0f 73 74 72 75 63 74 | 75 72 65 73 2e 6c 69 73 |..struct|ures.lis|
|00000010| 70 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |p.......|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 52 4f 53 | 41 01 00 00 00 00 00 00 |.TEXTROS|A.......|
|00000050| 00 00 00 00 00 12 0a 00 | 00 01 ac a9 b8 2c a7 a9 |........|.....,..|
|00000060| b8 2c a7 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |.,......|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 58 7a 00 00 |........|....Xz..|
|00000080| 3b 3b 0d 3b 3b 09 09 43 | 6f 70 79 72 69 67 68 74 |;;.;;..C|opyright|
|00000090| 20 a9 20 31 39 39 34 20 | 52 6f 67 65 72 20 43 6f | . 1994 |Roger Co|
|000000a0| 72 6d 61 6e 2e 20 20 41 | 6c 6c 20 72 69 67 68 74 |rman. A|ll right|
|000000b0| 73 20 72 65 73 65 72 76 | 65 64 2e 0d 3b 3b 0d 0d |s reserv|ed..;;..|
|000000c0| 3b 3b 09 09 50 6f 77 65 | 72 4c 69 73 70 20 53 74 |;;..Powe|rLisp St|
|000000d0| 72 75 63 74 75 72 65 20 | 66 61 63 69 6c 69 74 79 |ructure |facility|
|000000e0| 2e 0d 0d 28 70 72 6f 76 | 69 64 65 20 3a 73 74 72 |...(prov|ide :str|
|000000f0| 75 63 74 75 72 65 73 29 | 0d 28 69 6e 2d 70 61 63 |uctures)|.(in-pac|
|00000100| 6b 61 67 65 20 3a 63 6f | 6d 6d 6f 6e 2d 6c 69 73 |kage :co|mmon-lis|
|00000110| 70 29 0d 0d 28 64 65 66 | 6d 61 63 72 6f 20 64 65 |p)..(def|macro de|
|00000120| 66 73 74 72 75 63 74 20 | 28 6e 61 6d 65 2d 61 6e |fstruct |(name-an|
|00000130| 64 2d 6f 70 74 69 6f 6e | 73 20 26 72 65 73 74 20 |d-option|s &rest |
|00000140| 64 6f 63 2d 61 6e 64 2d | 73 6c 6f 74 73 29 0d 09 |doc-and-|slots)..|
|00000150| 28 6c 65 74 20 28 09 6e | 61 6d 65 20 0d 09 09 09 |(let (.n|ame ....|
|00000160| 6f 70 74 69 6f 6e 73 20 | 0d 09 09 09 64 6f 63 2d |options |....doc-|
|00000170| 73 74 72 69 6e 67 20 0d | 09 09 09 73 6c 6f 74 2d |string .|...slot-|
|00000180| 64 65 73 63 72 69 70 74 | 6f 72 73 20 0d 09 09 09 |descript|ors ....|
|00000190| 73 74 72 75 63 74 2d 74 | 65 6d 70 6c 61 74 65 0d |struct-t|emplate.|
|000001a0| 09 09 09 63 6f 6e 73 74 | 72 75 63 74 6f 72 2d 6e |...const|ructor-n|
|000001b0| 61 6d 65 0d 09 09 09 28 | 63 6f 6e 63 2d 6e 61 6d |ame....(|conc-nam|
|000001c0| 65 20 6e 69 6c 29 0d 09 | 09 09 63 6f 70 69 65 72 |e nil)..|..copier|
|000001d0| 2d 6e 61 6d 65 0d 09 09 | 09 70 72 65 64 69 63 61 |-name...|.predica|
|000001e0| 74 65 2d 6e 61 6d 65 0d | 09 09 09 61 63 63 65 73 |te-name.|...acces|
|000001f0| 73 6f 72 2d 6e 61 6d 65 | 0d 09 09 09 28 70 72 69 |sor-name|....(pri|
|00000200| 6e 74 2d 66 75 6e 63 74 | 69 6f 6e 20 6e 69 6c 29 |nt-funct|ion nil)|
|00000210| 0d 09 09 09 73 65 74 74 | 65 72 2d 6e 61 6d 65 0d |....sett|er-name.|
|00000220| 09 09 09 28 73 6c 6f 74 | 2d 6e 75 6d 62 65 72 20 |...(slot|-number |
|00000230| 30 29 0d 09 09 09 28 65 | 78 70 72 65 73 73 69 6f |0)....(e|xpressio|
|00000240| 6e 73 20 6e 69 6c 29 29 | 20 0d 09 09 09 0d 09 09 |ns nil))| .......|
|00000250| 28 69 66 20 28 73 79 6d | 62 6f 6c 70 20 6e 61 6d |(if (sym|bolp nam|
|00000260| 65 2d 61 6e 64 2d 6f 70 | 74 69 6f 6e 73 29 0d 09 |e-and-op|tions)..|
|00000270| 09 09 28 73 65 74 71 20 | 6e 61 6d 65 20 6e 61 6d |..(setq |name nam|
|00000280| 65 2d 61 6e 64 2d 6f 70 | 74 69 6f 6e 73 29 0d 09 |e-and-op|tions)..|
|00000290| 09 09 28 70 72 6f 67 6e | 0d 09 09 09 09 28 69 66 |..(progn|.....(if|
|000002a0| 20 28 6f 72 20 28 6e 6f | 74 20 28 63 6f 6e 73 70 | (or (no|t (consp|
|000002b0| 20 6e 61 6d 65 2d 61 6e | 64 2d 6f 70 74 69 6f 6e | name-an|d-option|
|000002c0| 73 29 29 20 28 6e 6f 74 | 20 28 73 79 6d 62 6f 6c |s)) (not| (symbol|
|000002d0| 70 20 28 63 61 72 20 6e | 61 6d 65 2d 61 6e 64 2d |p (car n|ame-and-|
|000002e0| 6f 70 74 69 6f 6e 73 29 | 29 29 29 0d 09 09 09 09 |options)|))).....|
|000002f0| 09 28 65 72 72 6f 72 20 | 22 49 6e 76 61 6c 69 64 |.(error |"Invalid|
|00000300| 20 73 79 6e 74 61 78 20 | 66 6f 72 20 64 65 66 73 | syntax |for defs|
|00000310| 74 72 75 63 74 20 6e 61 | 6d 65 3a 20 7e 41 22 20 |truct na|me: ~A" |
|00000320| 6e 61 6d 65 2d 61 6e 64 | 2d 6f 70 74 69 6f 6e 73 |name-and|-options|
|00000330| 29 29 0d 09 09 09 09 28 | 73 65 74 71 20 6e 61 6d |)).....(|setq nam|
|00000340| 65 20 28 63 61 72 20 6e | 61 6d 65 2d 61 6e 64 2d |e (car n|ame-and-|
|00000350| 6f 70 74 69 6f 6e 73 29 | 29 0d 09 09 09 09 28 73 |options)|).....(s|
|00000360| 65 74 71 20 6f 70 74 69 | 6f 6e 73 20 28 63 64 72 |etq opti|ons (cdr|
|00000370| 20 6e 61 6d 65 2d 61 6e | 64 2d 6f 70 74 69 6f 6e | name-an|d-option|
|00000380| 73 29 29 29 29 0d 0d 09 | 09 28 73 65 74 71 20 63 |s))))...|.(setq c|
|00000390| 6f 6e 63 2d 6e 61 6d 65 | 20 28 63 6f 6e 63 61 74 |onc-name| (concat|
|000003a0| 65 6e 61 74 65 20 27 73 | 74 72 69 6e 67 20 28 73 |enate 's|tring (s|
|000003b0| 79 6d 62 6f 6c 2d 6e 61 | 6d 65 20 6e 61 6d 65 29 |ymbol-na|me name)|
|000003c0| 20 22 2d 22 29 29 0d 0d | 09 09 28 64 6f 6c 69 73 | "-"))..|..(dolis|
|000003d0| 74 20 28 6f 70 74 20 6f | 70 74 69 6f 6e 73 29 0d |t (opt o|ptions).|
|000003e0| 09 09 09 28 63 6f 6e 64 | 0d 09 09 09 09 28 28 6b |...(cond|.....((k|
|000003f0| 65 79 77 6f 72 64 70 20 | 6f 70 74 29 29 0d 09 09 |eywordp |opt))...|
|00000400| 09 09 28 28 61 6e 64 20 | 28 6c 69 73 74 70 20 6f |..((and |(listp o|
|00000410| 70 74 29 20 28 6b 65 79 | 77 6f 72 64 70 20 28 63 |pt) (key|wordp (c|
|00000420| 61 72 20 6f 70 74 29 29 | 29 0d 09 09 09 09 20 28 |ar opt))|)..... (|
|00000430| 63 61 73 65 20 28 63 61 | 72 20 6f 70 74 29 0d 09 |case (ca|r opt)..|
|00000440| 09 09 09 09 28 3a 63 6f | 6e 63 2d 6e 61 6d 65 20 |....(:co|nc-name |
|00000450| 0d 09 09 09 09 09 09 28 | 69 66 20 28 63 64 72 20 |.......(|if (cdr |
|00000460| 6f 70 74 29 0d 09 09 09 | 09 09 09 09 28 73 65 74 |opt)....|....(set|
|00000470| 71 20 63 6f 6e 63 2d 6e | 61 6d 65 20 0d 09 09 09 |q conc-n|ame ....|
|00000480| 09 09 09 09 09 09 28 69 | 66 20 28 63 61 64 72 20 |......(i|f (cadr |
|00000490| 6f 70 74 29 20 0d 09 09 | 09 09 09 09 09 09 09 09 |opt) ...|........|
|000004a0| 28 73 79 6d 62 6f 6c 2d | 6e 61 6d 65 20 28 63 61 |(symbol-|name (ca|
|000004b0| 64 72 20 6f 70 74 29 29 | 0d 09 09 09 09 09 09 09 |dr opt))|........|
|000004c0| 09 09 09 22 22 29 29 29 | 29 0d 09 09 09 09 09 28 |..."")))|)......(|
|000004d0| 3a 63 6f 6e 73 74 72 75 | 63 74 6f 72 20 28 69 66 |:constru|ctor (if|
|000004e0| 20 28 63 64 72 20 6f 70 | 74 29 20 28 73 65 74 71 | (cdr op|t) (setq|
|000004f0| 20 63 6f 6e 73 74 72 75 | 63 74 6f 72 2d 6e 61 6d | constru|ctor-nam|
|00000500| 65 20 28 63 61 64 72 20 | 6f 70 74 29 29 29 29 0d |e (cadr |opt)))).|
|00000510| 09 09 09 09 09 28 3a 63 | 6f 70 69 65 72 20 28 69 |.....(:c|opier (i|
|00000520| 66 20 28 63 64 72 20 6f | 70 74 29 20 28 73 65 74 |f (cdr o|pt) (set|
|00000530| 71 20 63 6f 70 69 65 72 | 2d 6e 61 6d 65 20 28 63 |q copier|-name (c|
|00000540| 61 64 72 20 6f 70 74 29 | 29 29 29 0d 09 09 09 09 |adr opt)|))).....|
|00000550| 09 28 3a 70 72 65 64 69 | 63 61 74 65 20 28 69 66 |.(:predi|cate (if|
|00000560| 20 28 63 64 72 20 6f 70 | 74 29 20 28 73 65 74 71 | (cdr op|t) (setq|
|00000570| 20 70 72 65 64 69 63 61 | 74 65 2d 6e 61 6d 65 20 | predica|te-name |
|00000580| 28 63 61 64 72 20 6f 70 | 74 29 29 29 29 0d 09 09 |(cadr op|t))))...|
|00000590| 09 09 09 28 3a 69 6e 63 | 6c 75 64 65 20 28 65 72 |...(:inc|lude (er|
|000005a0| 72 6f 72 20 22 64 65 66 | 73 74 72 75 63 74 20 6f |ror "def|struct o|
|000005b0| 70 74 69 6f 6e 20 6e 6f | 74 20 69 6d 70 6c 65 6d |ption no|t implem|
|000005c0| 65 6e 74 65 64 3a 20 7e | 41 7e 25 22 20 28 63 61 |ented: ~|A~%" (ca|
|000005d0| 72 20 6f 70 74 29 29 29 | 0d 09 09 09 09 09 28 3a |r opt)))|......(:|
|000005e0| 70 72 69 6e 74 2d 66 75 | 6e 63 74 69 6f 6e 20 28 |print-fu|nction (|
|000005f0| 69 66 20 28 63 64 72 20 | 6f 70 74 29 20 28 73 65 |if (cdr |opt) (se|
|00000600| 74 71 20 70 72 69 6e 74 | 2d 66 75 6e 63 74 69 6f |tq print|-functio|
|00000610| 6e 20 28 63 61 64 72 20 | 6f 70 74 29 29 29 29 0d |n (cadr |opt)))).|
|00000620| 09 09 09 09 09 28 3a 74 | 79 70 65 20 28 65 72 72 |.....(:t|ype (err|
|00000630| 6f 72 20 22 64 65 66 73 | 74 72 75 63 74 20 6f 70 |or "defs|truct op|
|00000640| 74 69 6f 6e 20 6e 6f 74 | 20 69 6d 70 6c 65 6d 65 |tion not| impleme|
|00000650| 6e 74 65 64 3a 20 7e 41 | 7e 25 22 20 28 63 61 72 |nted: ~A|~%" (car|
|00000660| 20 6f 70 74 29 29 29 0d | 09 09 09 09 09 28 3a 6e | opt))).|.....(:n|
|00000670| 61 6d 65 64 20 74 29 0d | 09 09 09 09 09 28 3a 69 |amed t).|.....(:i|
|00000680| 6e 69 74 69 61 6c 2d 6f | 66 66 73 65 74 20 74 29 |nitial-o|ffset t)|
|00000690| 0d 09 09 09 09 09 28 6f | 74 68 65 72 77 69 73 65 |......(o|therwise|
|000006a0| 20 28 65 72 72 6f 72 20 | 22 55 6e 6b 6e 6f 77 6e | (error |"Unknown|
|000006b0| 20 64 65 66 73 74 72 75 | 63 74 20 6f 70 74 69 6f | defstru|ct optio|
|000006c0| 6e 3a 20 7e 41 7e 25 22 | 20 28 63 61 72 20 6f 70 |n: ~A~%"| (car op|
|000006d0| 74 29 29 29 29 29 0d 09 | 09 09 09 28 74 20 28 65 |t)))))..|...(t (e|
|000006e0| 72 72 6f 72 20 22 49 6e | 76 61 6c 69 64 20 64 65 |rror "In|valid de|
|000006f0| 66 73 74 72 75 63 74 20 | 6f 70 74 69 6f 6e 3a 20 |fstruct |option: |
|00000700| 7e 41 7e 25 22 20 6f 70 | 74 29 29 29 29 09 0d 0d |~A~%" op|t))))...|
|00000710| 09 09 28 69 66 20 28 73 | 74 72 69 6e 67 70 20 28 |..(if (s|tringp (|
|00000720| 63 61 72 20 64 6f 63 2d | 61 6e 64 2d 73 6c 6f 74 |car doc-|and-slot|
|00000730| 73 29 29 0d 09 09 09 28 | 70 72 6f 67 6e 0d 09 09 |s))....(|progn...|
|00000740| 09 09 28 73 65 74 71 20 | 64 6f 63 2d 73 74 72 69 |..(setq |doc-stri|
|00000750| 6e 67 20 28 63 61 72 20 | 64 6f 63 2d 61 6e 64 2d |ng (car |doc-and-|
|00000760| 73 6c 6f 74 73 29 29 0d | 09 09 09 09 28 73 65 74 |slots)).|....(set|
|00000770| 71 20 73 6c 6f 74 2d 64 | 65 73 63 72 69 70 74 6f |q slot-d|escripto|
|00000780| 72 73 20 28 63 64 72 20 | 64 6f 63 2d 61 6e 64 2d |rs (cdr |doc-and-|
|00000790| 73 6c 6f 74 73 29 29 29 | 0d 09 09 09 28 73 65 74 |slots)))|....(set|
|000007a0| 71 20 73 6c 6f 74 2d 64 | 65 73 63 72 69 70 74 6f |q slot-d|escripto|
|000007b0| 72 73 20 64 6f 63 2d 61 | 6e 64 2d 73 6c 6f 74 73 |rs doc-a|nd-slots|
|000007c0| 29 29 0d 09 09 0d 09 09 | 3b 3b 20 61 64 64 20 74 |))......|;; add t|
|000007d0| 68 65 20 64 6f 63 20 73 | 74 72 69 6e 67 20 77 69 |he doc s|tring wi|
|000007e0| 74 68 20 73 74 72 75 63 | 74 75 72 65 20 61 74 74 |th struc|ture att|
|000007f0| 72 69 62 75 74 65 09 0d | 09 09 28 69 66 20 64 6f |ribute..|..(if do|
|00000800| 63 2d 73 74 72 69 6e 67 | 0d 09 09 09 28 70 75 73 |c-string|....(pus|
|00000810| 68 20 0d 09 09 09 09 60 | 28 73 65 74 66 20 28 64 |h .....`|(setf (d|
|00000820| 6f 63 75 6d 65 6e 74 61 | 74 69 6f 6e 20 27 2c 6e |ocumenta|tion ',n|
|00000830| 61 6d 65 20 27 73 74 72 | 75 63 74 75 72 65 29 20 |ame 'str|ucture) |
|00000840| 2c 64 6f 63 2d 73 74 72 | 69 6e 67 29 20 0d 09 09 |,doc-str|ing) ...|
|00000850| 09 09 65 78 70 72 65 73 | 73 69 6f 6e 73 29 29 0d |..expres|sions)).|
|00000860| 09 09 0d 09 09 3b 3b 20 | 70 72 6f 63 65 73 73 20 |.....;; |process |
|00000870| 73 6c 6f 74 20 6f 70 74 | 69 6f 6e 73 0d 09 09 28 |slot opt|ions...(|
|00000880| 70 75 73 68 20 6e 61 6d | 65 20 73 74 72 75 63 74 |push nam|e struct|
|00000890| 2d 74 65 6d 70 6c 61 74 | 65 29 0d 09 09 0d 09 09 |-templat|e)......|
|000008a0| 28 64 6f 6c 69 73 74 20 | 28 6f 70 74 20 73 6c 6f |(dolist |(opt slo|
|000008b0| 74 2d 64 65 73 63 72 69 | 70 74 6f 72 73 29 0d 09 |t-descri|ptors)..|
|000008c0| 09 09 28 63 6f 6e 64 0d | 09 09 09 09 28 28 73 79 |..(cond.|....((sy|
|000008d0| 6d 62 6f 6c 70 20 6f 70 | 74 29 20 20 0d 09 09 09 |mbolp op|t) ....|
|000008e0| 09 09 28 70 75 73 68 20 | 28 69 6e 74 65 72 6e 20 |..(push |(intern |
|000008f0| 28 73 79 6d 62 6f 6c 2d | 6e 61 6d 65 20 6f 70 74 |(symbol-|name opt|
|00000900| 29 20 3a 6b 65 79 77 6f | 72 64 29 20 73 74 72 75 |) :keywo|rd) stru|
|00000910| 63 74 2d 74 65 6d 70 6c | 61 74 65 29 0d 09 09 09 |ct-templ|ate)....|
|00000920| 09 09 28 70 75 73 68 20 | 6e 69 6c 20 73 74 72 75 |..(push |nil stru|
|00000930| 63 74 2d 74 65 6d 70 6c | 61 74 65 29 29 0d 09 09 |ct-templ|ate))...|
|00000940| 09 09 28 28 63 6f 6e 73 | 70 20 6f 70 74 29 0d 09 |..((cons|p opt)..|
|00000950| 09 09 09 09 28 6c 65 74 | 20 28 28 73 79 6d 20 28 |....(let| ((sym (|
|00000960| 63 61 72 20 6f 70 74 29 | 29 29 0d 09 09 09 09 09 |car opt)|))......|
|00000970| 09 28 69 66 20 28 6e 6f | 74 20 28 73 79 6d 62 6f |.(if (no|t (symbo|
|00000980| 6c 70 20 73 79 6d 29 29 | 0d 09 09 09 09 09 09 09 |lp sym))|........|
|00000990| 28 65 72 72 6f 72 20 22 | 49 6e 76 61 6c 69 64 20 |(error "|Invalid |
|000009a0| 73 6c 6f 74 20 64 65 73 | 63 72 69 70 74 6f 72 3a |slot des|criptor:|
|000009b0| 20 7e 41 7e 25 22 20 73 | 79 6d 29 29 09 09 09 09 | ~A~%" s|ym))....|
|000009c0| 09 0d 09 09 09 09 09 09 | 28 70 75 73 68 20 28 69 |........|(push (i|
|000009d0| 6e 74 65 72 6e 20 28 73 | 79 6d 62 6f 6c 2d 6e 61 |ntern (s|ymbol-na|
|000009e0| 6d 65 20 73 79 6d 29 20 | 3a 6b 65 79 77 6f 72 64 |me sym) |:keyword|
|000009f0| 29 20 73 74 72 75 63 74 | 2d 74 65 6d 70 6c 61 74 |) struct|-templat|
|00000a00| 65 29 0d 09 09 09 09 09 | 09 28 70 75 73 68 20 28 |e)......|.(push (|
|00000a10| 63 61 64 72 20 6f 70 74 | 29 20 73 74 72 75 63 74 |cadr opt|) struct|
|00000a20| 2d 74 65 6d 70 6c 61 74 | 65 29 29 29 0d 09 09 09 |-templat|e)))....|
|00000a30| 09 28 74 20 28 65 72 72 | 6f 72 20 22 49 6e 76 61 |.(t (err|or "Inva|
|00000a40| 6c 69 64 20 73 6c 6f 74 | 20 6f 70 74 69 6f 6e 3a |lid slot| option:|
|00000a50| 20 7e 41 7e 25 22 20 6f | 70 74 29 29 29 29 0d 0d | ~A~%" o|pt))))..|
|00000a60| 09 09 3b 3b 20 69 6e 73 | 74 61 6c 6c 20 74 65 6d |..;; ins|tall tem|
|00000a70| 70 6c 61 74 65 09 09 0d | 09 09 28 70 75 73 68 0d |plate...|..(push.|
|00000a80| 09 09 09 60 28 73 65 74 | 66 20 28 67 65 74 20 27 |...`(set|f (get '|
|00000a90| 2c 6e 61 6d 65 20 3a 73 | 74 72 75 63 74 2d 74 65 |,name :s|truct-te|
|00000aa0| 6d 70 6c 61 74 65 29 20 | 0d 09 09 09 09 28 61 70 |mplate) |.....(ap|
|00000ab0| 70 6c 79 20 23 27 64 65 | 66 69 6e 65 2d 73 74 72 |ply #'de|fine-str|
|00000ac0| 75 63 74 2d 74 65 6d 70 | 6c 61 74 65 20 27 2c 28 |uct-temp|late ',(|
|00000ad0| 72 65 76 65 72 73 65 20 | 73 74 72 75 63 74 2d 74 |reverse |struct-t|
|00000ae0| 65 6d 70 6c 61 74 65 29 | 29 29 0d 09 09 09 65 78 |emplate)|))....ex|
|00000af0| 70 72 65 73 73 69 6f 6e | 73 29 0d 0d 09 09 3b 3b |pression|s)....;;|
|00000b00| 20 69 6e 73 74 61 6c 6c | 20 70 72 69 6e 74 20 66 | install| print f|
|00000b10| 75 6e 63 74 69 6f 6e 09 | 09 0d 09 09 28 69 66 20 |unction.|....(if |
|00000b20| 70 72 69 6e 74 2d 66 75 | 6e 63 74 69 6f 6e 0d 09 |print-fu|nction..|
|00000b30| 09 09 28 70 75 73 68 0d | 09 09 09 09 60 28 73 65 |..(push.|....`(se|
|00000b40| 74 66 20 28 67 65 74 20 | 27 2c 6e 61 6d 65 20 3a |tf (get |',name :|
|00000b50| 73 74 72 75 63 74 2d 70 | 72 69 6e 74 29 20 0d 09 |struct-p|rint) ..|
|00000b60| 09 09 09 09 28 66 75 6e | 63 74 69 6f 6e 20 2c 70 |....(fun|ction ,p|
|00000b70| 72 69 6e 74 2d 66 75 6e | 63 74 69 6f 6e 29 29 0d |rint-fun|ction)).|
|00000b80| 09 09 09 09 65 78 70 72 | 65 73 73 69 6f 6e 73 29 |....expr|essions)|
|00000b90| 29 0d 09 09 09 0d 09 09 | 3b 3b 20 69 6e 73 74 61 |).......|;; insta|
|00000ba0| 6c 6c 20 63 6f 6e 73 74 | 72 75 63 74 6f 72 20 66 |ll const|ructor f|
|00000bb0| 75 6e 63 74 69 6f 6e 09 | 09 09 0d 09 09 28 73 65 |unction.|.....(se|
|00000bc0| 74 71 20 63 6f 6e 73 74 | 72 75 63 74 6f 72 2d 6e |tq const|ructor-n|
|00000bd0| 61 6d 65 0d 09 09 09 28 | 69 66 20 63 6f 6e 73 74 |ame....(|if const|
|00000be0| 72 75 63 74 6f 72 2d 6e | 61 6d 65 20 0d 09 09 09 |ructor-n|ame ....|
|00000bf0| 09 28 69 6e 74 65 72 6e | 20 28 73 79 6d 62 6f 6c |.(intern| (symbol|
|00000c00| 2d 6e 61 6d 65 20 63 6f | 6e 73 74 72 75 63 74 6f |-name co|nstructo|
|00000c10| 72 2d 6e 61 6d 65 29 29 | 0d 09 09 09 09 28 69 6e |r-name))|.....(in|
|00000c20| 74 65 72 6e 20 28 63 6f | 6e 63 61 74 65 6e 61 74 |tern (co|ncatenat|
|00000c30| 65 20 27 73 74 72 69 6e | 67 20 22 4d 41 4b 45 2d |e 'strin|g "MAKE-|
|00000c40| 22 20 28 73 79 6d 62 6f | 6c 2d 6e 61 6d 65 20 6e |" (symbo|l-name n|
|00000c50| 61 6d 65 29 29 29 29 29 | 0d 09 09 09 0d 09 09 28 |ame)))))|.......(|
|00000c60| 70 75 73 68 0d 09 09 09 | 60 28 73 65 74 66 20 28 |push....|`(setf (|
|00000c70| 73 79 6d 62 6f 6c 2d 66 | 75 6e 63 74 69 6f 6e 20 |symbol-f|unction |
|00000c80| 27 2c 63 6f 6e 73 74 72 | 75 63 74 6f 72 2d 6e 61 |',constr|uctor-na|
|00000c90| 6d 65 29 0d 09 09 09 09 | 23 27 28 6c 61 6d 62 64 |me).....|#'(lambd|
|00000ca0| 61 20 28 26 72 65 73 74 | 20 61 72 67 73 29 20 0d |a (&rest| args) .|
|00000cb0| 09 09 09 09 09 28 5f 6d | 61 6b 65 2d 73 74 72 75 |.....(_m|ake-stru|
|00000cc0| 63 74 20 28 67 65 74 20 | 27 2c 6e 61 6d 65 20 3a |ct (get |',name :|
|00000cd0| 73 74 72 75 63 74 2d 74 | 65 6d 70 6c 61 74 65 29 |struct-t|emplate)|
|00000ce0| 20 61 72 67 73 29 29 29 | 0d 09 09 09 65 78 70 72 | args)))|....expr|
|00000cf0| 65 73 73 69 6f 6e 73 29 | 0d 09 09 0d 09 09 3b 3b |essions)|......;;|
|00000d00| 20 69 6e 73 74 61 6c 6c | 20 63 6f 70 69 65 72 20 | install| copier |
|00000d10| 66 75 6e 63 74 69 6f 6e | 09 09 09 0d 09 09 28 73 |function|......(s|
|00000d20| 65 74 71 20 63 6f 70 69 | 65 72 2d 6e 61 6d 65 0d |etq copi|er-name.|
|00000d30| 09 09 09 28 69 66 20 63 | 6f 70 69 65 72 2d 6e 61 |...(if c|opier-na|
|00000d40| 6d 65 20 0d 09 09 09 09 | 28 69 6e 74 65 72 6e 20 |me .....|(intern |
|00000d50| 28 73 79 6d 62 6f 6c 2d | 6e 61 6d 65 20 63 6f 70 |(symbol-|name cop|
|00000d60| 69 65 72 2d 6e 61 6d 65 | 29 29 0d 09 09 09 09 28 |ier-name|)).....(|
|00000d70| 69 6e 74 65 72 6e 20 28 | 63 6f 6e 63 61 74 65 6e |intern (|concaten|
|00000d80| 61 74 65 20 27 73 74 72 | 69 6e 67 20 22 43 4f 50 |ate 'str|ing "COP|
|00000d90| 59 2d 22 20 28 73 79 6d | 62 6f 6c 2d 6e 61 6d 65 |Y-" (sym|bol-name|
|00000da0| 20 6e 61 6d 65 29 29 29 | 29 29 0d 09 09 09 0d 09 | name)))|))......|
|00000db0| 09 28 70 75 73 68 0d 09 | 09 09 60 28 73 65 74 66 |.(push..|..`(setf|
|00000dc0| 20 28 73 79 6d 62 6f 6c | 2d 66 75 6e 63 74 69 6f | (symbol|-functio|
|00000dd0| 6e 20 27 2c 63 6f 70 69 | 65 72 2d 6e 61 6d 65 29 |n ',copi|er-name)|
|00000de0| 0d 09 09 09 09 23 27 28 | 6c 61 6d 62 64 61 20 28 |.....#'(|lambda (|
|00000df0| 61 72 67 29 20 28 63 6c | 6f 6e 65 2d 73 74 72 75 |arg) (cl|one-stru|
|00000e00| 63 74 20 61 72 67 29 29 | 29 0d 09 09 09 65 78 70 |ct arg))|)....exp|
|00000e10| 72 65 73 73 69 6f 6e 73 | 29 0d 09 09 0d 09 09 3b |ressions|)......;|
|00000e20| 3b 20 69 6e 73 74 61 6c | 6c 20 70 72 65 64 69 63 |; instal|l predic|
|00000e30| 61 74 65 20 66 75 6e 63 | 74 69 6f 6e 09 09 09 0d |ate func|tion....|
|00000e40| 09 09 28 73 65 74 71 20 | 70 72 65 64 69 63 61 74 |..(setq |predicat|
|00000e50| 65 2d 6e 61 6d 65 0d 09 | 09 09 28 69 66 20 70 72 |e-name..|..(if pr|
|00000e60| 65 64 69 63 61 74 65 2d | 6e 61 6d 65 20 0d 09 09 |edicate-|name ...|
|00000e70| 09 09 28 69 6e 74 65 72 | 6e 20 28 73 79 6d 62 6f |..(inter|n (symbo|
|00000e80| 6c 2d 6e 61 6d 65 20 70 | 72 65 64 69 63 61 74 65 |l-name p|redicate|
|00000e90| 2d 6e 61 6d 65 29 29 0d | 09 09 09 09 28 69 6e 74 |-name)).|....(int|
|00000ea0| 65 72 6e 20 28 63 6f 6e | 63 61 74 65 6e 61 74 65 |ern (con|catenate|
|00000eb0| 20 27 73 74 72 69 6e 67 | 20 28 73 79 6d 62 6f 6c | 'string| (symbol|
|00000ec0| 2d 6e 61 6d 65 20 6e 61 | 6d 65 29 20 22 2d 50 22 |-name na|me) "-P"|
|00000ed0| 29 29 29 29 0d 09 09 09 | 0d 09 09 28 70 75 73 68 |))))....|...(push|
|00000ee0| 0d 09 09 09 60 28 73 65 | 74 66 20 28 73 79 6d 62 |....`(se|tf (symb|
|00000ef0| 6f 6c 2d 66 75 6e 63 74 | 69 6f 6e 20 27 2c 70 72 |ol-funct|ion ',pr|
|00000f00| 65 64 69 63 61 74 65 2d | 6e 61 6d 65 29 0d 09 09 |edicate-|name)...|
|00000f10| 09 09 23 27 28 6c 61 6d | 62 64 61 20 28 61 72 67 |..#'(lam|bda (arg|
|00000f20| 29 20 28 5f 63 68 65 63 | 6b 2d 73 74 72 75 63 74 |) (_chec|k-struct|
|00000f30| 2d 74 79 70 65 20 61 72 | 67 20 27 2c 6e 61 6d 65 |-type ar|g ',name|
|00000f40| 29 29 29 0d 09 09 09 65 | 78 70 72 65 73 73 69 6f |)))....e|xpressio|
|00000f50| 6e 73 29 0d 09 09 0d 09 | 09 3b 3b 20 69 6e 73 74 |ns).....|.;; inst|
|00000f60| 61 6c 6c 20 61 63 63 65 | 73 73 6f 72 20 66 75 6e |all acce|ssor fun|
|00000f70| 63 74 69 6f 6e 73 0d 09 | 09 0d 09 09 28 64 6f 6c |ctions..|....(dol|
|00000f80| 69 73 74 20 28 73 6c 6f | 74 20 73 6c 6f 74 2d 64 |ist (slo|t slot-d|
|00000f90| 65 73 63 72 69 70 74 6f | 72 73 29 0d 09 09 0d 09 |escripto|rs).....|
|00000fa0| 09 09 3b 3b 20 69 6e 73 | 74 61 6c 6c 20 61 63 63 |..;; ins|tall acc|
|00000fb0| 65 73 73 6f 72 20 66 75 | 6e 63 74 69 6f 6e 20 66 |essor fu|nction f|
|00000fc0| 6f 72 20 74 68 69 73 20 | 73 6c 6f 74 09 09 09 0d |or this |slot....|
|00000fd0| 09 09 09 28 73 65 74 71 | 20 61 63 63 65 73 73 6f |...(setq| accesso|
|00000fe0| 72 2d 6e 61 6d 65 20 0d | 09 09 09 09 28 69 6e 74 |r-name .|....(int|
|00000ff0| 65 72 6e 20 0d 09 09 09 | 09 09 28 63 6f 6e 63 61 |ern ....|..(conca|
|00001000| 74 65 6e 61 74 65 20 27 | 73 74 72 69 6e 67 20 63 |tenate '|string c|
|00001010| 6f 6e 63 2d 6e 61 6d 65 | 20 0d 09 09 09 09 09 09 |onc-name| .......|
|00001020| 28 73 79 6d 62 6f 6c 2d | 6e 61 6d 65 20 28 69 66 |(symbol-|name (if|
|00001030| 20 28 73 79 6d 62 6f 6c | 70 20 73 6c 6f 74 29 20 | (symbol|p slot) |
|00001040| 73 6c 6f 74 20 28 63 61 | 72 20 73 6c 6f 74 29 29 |slot (ca|r slot))|
|00001050| 29 29 29 29 0d 09 09 09 | 0d 09 09 09 28 70 75 73 |))))....|....(pus|
|00001060| 68 0d 09 09 09 09 60 28 | 73 65 74 66 20 28 73 79 |h.....`(|setf (sy|
|00001070| 6d 62 6f 6c 2d 66 75 6e | 63 74 69 6f 6e 20 27 2c |mbol-fun|ction ',|
|00001080| 61 63 63 65 73 73 6f 72 | 2d 6e 61 6d 65 29 0d 09 |accessor|-name)..|
|00001090| 09 09 09 09 23 27 28 6c | 61 6d 62 64 61 20 28 61 |....#'(l|ambda (a|
|000010a0| 72 67 29 20 28 67 65 74 | 2d 73 74 72 75 63 74 2d |rg) (get|-struct-|
|000010b0| 66 69 65 6c 64 20 61 72 | 67 20 2c 73 6c 6f 74 2d |field ar|g ,slot-|
|000010c0| 6e 75 6d 62 65 72 29 29 | 29 0d 09 09 09 09 65 78 |number))|).....ex|
|000010d0| 70 72 65 73 73 69 6f 6e | 73 29 0d 0d 09 09 09 28 |pression|s).....(|
|000010e0| 73 65 74 71 20 73 65 74 | 74 65 72 2d 6e 61 6d 65 |setq set|ter-name|
|000010f0| 20 28 69 6e 74 65 72 6e | 20 28 63 6f 6e 63 61 74 | (intern| (concat|
|00001100| 65 6e 61 74 65 20 27 73 | 74 72 69 6e 67 20 22 25 |enate 's|tring "%|
|00001110| 53 45 54 2d 22 20 28 73 | 79 6d 62 6f 6c 2d 6e 61 |SET-" (s|ymbol-na|
|00001120| 6d 65 20 61 63 63 65 73 | 73 6f 72 2d 6e 61 6d 65 |me acces|sor-name|
|00001130| 29 29 29 29 09 09 0d 09 | 09 09 0d 09 09 09 28 70 |))))....|......(p|
|00001140| 75 73 68 0d 09 09 09 09 | 60 28 73 65 74 66 20 28 |ush.....|`(setf (|
|00001150| 73 79 6d 62 6f 6c 2d 66 | 75 6e 63 74 69 6f 6e 20 |symbol-f|unction |
|00001160| 27 2c 73 65 74 74 65 72 | 2d 6e 61 6d 65 29 0d 09 |',setter|-name)..|
|00001170| 09 09 09 09 23 27 28 6c | 61 6d 62 64 61 20 28 61 |....#'(l|ambda (a|
|00001180| 72 67 20 76 61 6c 75 65 | 29 20 28 73 65 74 2d 73 |rg value|) (set-s|
|00001190| 74 72 75 63 74 2d 66 69 | 65 6c 64 20 61 72 67 20 |truct-fi|eld arg |
|000011a0| 2c 73 6c 6f 74 2d 6e 75 | 6d 62 65 72 20 76 61 6c |,slot-nu|mber val|
|000011b0| 75 65 29 29 29 0d 09 09 | 09 09 65 78 70 72 65 73 |ue)))...|..expres|
|000011c0| 73 69 6f 6e 73 29 0d 09 | 09 09 28 70 75 73 68 20 |sions)..|..(push |
|000011d0| 60 28 64 65 66 73 65 74 | 66 20 2c 61 63 63 65 73 |`(defset|f ,acces|
|000011e0| 73 6f 72 2d 6e 61 6d 65 | 20 2c 73 65 74 74 65 72 |sor-name| ,setter|
|000011f0| 2d 6e 61 6d 65 29 20 65 | 78 70 72 65 73 73 69 6f |-name) e|xpressio|
|00001200| 6e 73 29 09 0d 09 09 09 | 28 73 65 74 71 20 73 6c |ns).....|(setq sl|
|00001210| 6f 74 2d 6e 75 6d 62 65 | 72 20 28 31 2b 20 73 6c |ot-numbe|r (1+ sl|
|00001220| 6f 74 2d 6e 75 6d 62 65 | 72 29 29 29 0d 0d 09 09 |ot-numbe|r)))....|
|00001230| 28 70 75 73 68 20 60 27 | 2c 6e 61 6d 65 20 65 78 |(push `'|,name ex|
|00001240| 70 72 65 73 73 69 6f 6e | 73 29 09 0d 09 09 28 63 |pression|s)....(c|
|00001250| 6f 6e 73 20 27 70 72 6f | 67 6e 20 28 72 65 76 65 |ons 'pro|gn (reve|
|00001260| 72 73 65 20 65 78 70 72 | 65 73 73 69 6f 6e 73 29 |rse expr|essions)|
|00001270| 29 29 29 0d 0d 0d 0d 0d | 0d 0d 0d 0d 0d 0d 0d 0d |))).....|........|
|00001280| 0d 0d 0d 0d 0d 0d 0d 0d | 0d 0d 00 00 00 00 00 00 |........|........|
|00001290| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000012a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000012b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000012c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000012d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000012e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000012f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001300| 00 00 01 00 00 00 01 6e | 00 00 00 6e 00 00 00 3e |.......n|...n...>|
|00001310| 65 20 28 78 29 0d 09 60 | 28 6c 65 74 20 28 28 74 |e (x)..`|(let ((t|
|00001320| 6d 20 28 67 65 74 2d 69 | 6e 74 65 72 6e 61 6c 2d |m (get-i|nternal-|
|00001330| 0f 73 74 72 75 63 74 75 | 72 65 73 2e 6c 69 73 70 |.structu|res.lisp|
|00001340| 02 00 00 00 54 45 58 54 | 52 4f 53 41 01 00 ff ff |....TEXT|ROSA....|
|00001350| 00 00 54 45 58 54 52 4f | 53 41 01 00 ff ff ff ff |..TEXTRO|SA......|
|00001360| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001370| 00 00 a8 c2 b3 bc 00 00 | 12 0a 00 00 01 ac 64 65 |........|......de|
|00001380| 63 66 20 74 6d 20 28 25 | 65 6c 61 70 73 65 64 2d |cf tm (%|elapsed-|
|00001390| 74 69 6d 65 20 6e 69 6c | 29 29 09 3b 3b 20 73 75 |time nil|)).;; su|
|000013a0| 62 74 72 61 63 74 20 74 | 69 6d 65 72 20 6f 76 65 |btract t|imer ove|
|000013b0| 72 68 65 61 64 0d 09 09 | 28 73 65 74 71 20 74 6d |rhead...|(setq tm|
|000013c0| 20 28 2f 20 28 66 6c 6f | 61 74 20 74 6d 29 20 31 | (/ (flo|at tm) 1|
|000013d0| 30 30 30 30 30 30 2e 30 | 29 29 0d 09 09 28 66 6f |000000.0|))...(fo|
|000013e0| 72 6d 61 74 20 2a 74 72 | 61 63 65 2d 6f 75 74 70 |rmat *tr|ace-outp|
|000013f0| 75 74 2a 20 22 45 78 65 | 63 75 74 69 6f 6e 20 74 |ut* "Exe|cution t|
|00001400| 00 00 00 48 00 09 4d 6f | 6e 61 63 6f 00 00 00 00 |...H..Mo|naco....|
|00001410| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001420| 00 00 00 00 00 00 00 06 | 00 04 00 3c 00 23 02 5e |........|...<.#.^|
|00001430| 02 7b 00 3c 00 23 02 5e | 02 7b a9 b7 f4 67 00 00 |.{.<.#.^|.{...g..|
|00001440| 00 00 00 00 00 3f 00 00 | 00 00 00 00 00 00 00 1e |.....?..|........|
|00001450| 00 3c 00 23 02 5e 02 7b | 00 3c 00 23 02 5e 02 7b |.<.#.^.{|.<.#.^.{|
|00001460| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001470| 01 00 00 00 01 6e 00 00 | 00 6e 00 00 00 3e 00 ff |.....n..|.n...>..|
|00001480| 03 38 1b 8c 00 00 00 1c | 00 3e 00 00 4d 50 53 52 |.8......|.>..MPSR|
|00001490| 00 01 00 0a 03 ed ff ff | 00 00 00 00 00 00 00 00 |........|........|
|000014a0| 03 f0 ff ff 00 00 00 4c | 01 01 59 c0 00 00 00 00 |.......L|..Y.....|
|000014b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000014c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000014d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000014e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000014f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+